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MULTICAST SYSTEM USING CLIENT FORWARDING 



FIELD OF THE INVENTION 

The present invention relates generally to transmitting information over a 
network. More specifically, a multicast system that uses clients to forward packets is 
disclosed. 

BACKGROUND OF THE INVENTION 

For some time now, network architects have been designing multicast (also 
referred to as point to multipoint or one to many) systems for delivering information from 
a source to a subset of the users on a network. Multicast systems have not generally 
enjoyed the same widespread adoption as unicast (one to one) and broadcast (one to all) 
systems. 

Various factors have made adoption of multicast systems difficult over large 
diverse networks. The problem of managing subscribing and unsubscribing users to 
multicast groups has proven difficult. Furthermore, in most multicast schemes, it is 
necessary that each router in the network be multicast enabled so that it can manage the 
distribution of packets to the correct nodes. Although later versions of the IP protocol 
have included multicast, legacy routers may not support multicast and there has been 
some difficulty settling on a widely adopted multicast standard. The issue of security is 
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also a problem. Preventing unauthorized users from accessing packets sent from routers 
to multicast group members is difficult. 

Some "multicast" solutions implemented today over a diverse network are 
actually just large scale implementations of multiple unicast systems. 

Figure 1 is a diagram illustrating a prior art multicast scheme implemented using 
a set of servers that unicast packets to clients in the "multicast" group. A set of servers 
102 sends packets 110 through a heterogeneous network 104. Heterogeneous network 
104 includes a number of routers 106, some of which are not shown. Routers 106 may 
include legacy routers that do not support multicasting. As a result, servers 102 must 
implement multicasting by actually unicasting packets to a set of clients 108. This is 
illustrated by the letter identifying each of the clients on the packets 110 sent from the 
servers. Obviously, this arrangement taxes the processing resources of the servers as 
each new client requires a new set of packets to be sent from one of the servers. 

It would be useful if a multicast system could be designed that would work with 
legacy routers that are not multicast enabled in a heterogeneous network, yet would not 
require the servers to send packets to each of the multicast clients. 
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SUMMARY OF THE INVENTION 

A multicast system that uses clients to forward packets to other clients is 
described. A multicast server handles signing up primary clients and directing 
transmitting packets to the primary clients. In addition, the multicast server directs the 
primary clients to forward information packets to the next level of receiving clients. The 
receiving clients may in turn transmit packets to another level of receiving clients. By 
cascading clients in this manner, information may be disseminated among a large group 
of clients very quickly. The server may decide which clients belong in which level of the 
forwarding tree of clients by determining the client location and/or the client performance 
in either receiving or transmitting data. 

As new clients sign up, existing clients are evaluated as candidates to transmit to 
the new client based on their network location, performance, or both. A new client may 
also be selected as a primary client, receiving information directly from the server. The 
failure of a client to transmit information is detected by the server and the clients 
receiving information from that client are redirected to a new source. The source may 
either be another client, the server itself, or a dedicated server used to transmit 
information to clients that have been clients of a failed source. 

It should be appreciated that the present invention can be implemented in 
numerous ways, including as a process, an apparatus, a system, a device, a method, or a 
computer readable medium such as a computer readable storage medium or a computer 
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network wherein program instructions are sent over optical or electronic communication 
links. Several inventive embodiments of the present invention are described below. 

In one embodiment, a method of multicasting information to a set of clients 
includes transmitting the information to a primary client from a server and instructing the 
primary client to forward the information to a secondary client. 

In one embodiment, a method of multicasting information to a set of clients 
includes determining a performance parameter for each of the clients and selecting a 
subset of the clients to be primary clients based on the performance parameter. The 
information is transmitted to the primary clients for retransmission to other clients in the 
set of clients. 

In one embodiment, a method of multicasting information to a set of clients 
includes determining a network location for each of the clients and selecting a subset of 
the clients to be primary clients based on the network location. The information is 
transmitted to the primary clients for retransmission to other clients in the set of clients. 

In one embodiment, a method of multicasting information to a set of clients 
includes determining a network location for each of the clients and determining a 
performance parameter for each of the clients. A subset of the clients is selected to be 
primary clients based on the performance parameter and the determined network location. 
The information is transmitted to the primary clients for retransmission other clients in 
the set of clients. 
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In one embodiment, a method of adding a new client to a multicast group includes 
receiving a request from the new client to subscribe to the multicast group and selecting 
an existing client to transmit information to the new client based on the network locations 
of the new client and the existing client, and a comparison of a performance parameter of 
the existing client with performance parameters of other existing clients. 

In one embodiment, a method of subscribing to a multicast group includes 
sending a request to a server from a subscribing client to subscribe to the multicast group 
and receiving from the server an identifier of a transmitting client that will send data to 
the subscribing client. Data is received from the transmitting client. 

In one embodiment, a method of forwarding information from a transmitting 
client to a receiving client in a multicast group includes receiving an instruction from a 
multicast server to forward information to the receiving client and receiving the 
information. The information is forwarded to the receiving client. 

In one embodiment, a method of redirecting a receiving multicast client from a 
failed transmitting client includes receiving a message from the receiving client that 
information is not being received and sending a message to the receiving client indicating 
a new source of the information. A message is sent to the new source directing the new 
source to send the information to the receiving client. 

In one embodiment, a method of redirecting a receiving multicast client from an 
under performing transmitting client includes receiving a message from the receiving 
client indicating the rate that information is being received and determining that the 
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information rate falls below a performance standard. A message is sent to the receiving 
client indicating a new source of the information and a message is sent to the new source 
directing the new source to send the information to the receiving client. 

In one embodiment, a server is configured to multicast information to a set of 
clients. The server includes a client interface configured to transmit the information to a 
primary client from the server and to instruct the primary client to forward the 
information to a secondary client. 

In one embodiment, a first client is configured to forward multicast information to 
another client. The first client includes a server interface configured to receive the 
information from the server and a client interface configured to forward the information 
to the other client. 

In one embodiment, a system for multicasting information to a set of clients 
includes a server configured to transmit the information and a primary client configured 
to receive the transmitted information and to forward the information to a secondary 
client. 

In one embodiment, a computer program product for multicasting information is 
embodied in a computer readable medium and includes instructions for transmitting the 
information to a primary client from a server and instructing the primary client to forward 
the information to a secondary client. 
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These and other features and advantages of the present invention will be presented 
in more detail in the following detailed description and the accompanying figures which 
illustrate by way of example the principles of the invention. 
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BRIEF DESCRIPTION OF THE DRAWINGS 



The present invention will be readily understood by the following detailed 
description in conjunction with the accompanying drawings, wherein like reference 
numerals designate like structural elements, and in which: 

Figure 1 is a diagram illustrating a prior art multicast scheme implemented using 
a set of servers that unicast packets to clients in the "multicast" group. 

Figure 2 A is a block diagram illustrating a network where a server 201 manages a 
multicast to a set of clients 202 through a network of routers 204 that are not necessarily 
multicast enabled. 

Figure 2B is a block diagram illustrating the topology of the data network. A 
server 210 provides multicast data to a web of clients 212. 

Figure 3 A is a block diagram illustrating the structure of a server used in one 
embodiment. 

Figure 3B is a block diagram illustrating the structure of a client. A processor 310 
is connected to a user interface 312. 

Figure 4 is a flowchart illustrating a process implemented on the server for 
signing up a new client. 

Figure 5 is a flowchart illustrating a process implemented on the server for 
beginning a multicast with a multiple number of clients. 
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Figure 6A is a diagram illustrating a primary client data structure used in the 
server to store a list of primary clients. 

Figure 6B is a diagram illustrating a client record that may be kept by the server 
for each of the clients. 

Figure 7 is a flowchart illustrating a process implemented on the server for 
monitoring clients. 

Figure 8 is a flowchart illustrating a process implemented on the server for 
reassigning clients of a failed transmitting client to a new transmitting client. 

Figure 9A is a flowchart illustrating a process for sending an error message. 

Figure 9B is a flowchart illustrating a process for sending statistics to the server. 
The process starts at 910. 

Figure 9C is a flowchart illustrating a process implemented on a client to forward 
packets to another client. 
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DETAILED DESCRIPTION 

A detailed description of a preferred embodiment of the invention is provided 
below. While the invention is described in conjunction with that preferred embodiment, 
it should be understood that the invention is not limited to any one embodiment. On the 
contrary, the scope of the invention is limited only by the appended claims and the 
invention encompasses numerous alternatives, modifications and equivalents. For the 
purpose of example, numerous specific details are set forth in the following description in 
order to provide a thorough understanding of the present invention. The present 
invention may be practiced according to the claims without some or all of these specific 
details. For the purpose of clarity, technical material that is known in the technical fields 
related to the invention has not been described in detail so that the present invention is 
not unnecessarily obscured. 

Figure 2A is a block diagram illustrating a network where a server 201 manages a 
multicast to a set of clients 202 through a network of routers 204 that are not necessarily 
multicast enabled. Server 201 receives requests from the group of clients or otherwise 
determines that clients should be added to a multicast list. Server 201 then establishes 
connections with some or all of the clients for the purpose of determining a subset of 
clients that are able to receive information from the server and process it quickly. The 
clients that are determined to have good performance are designated as primary clients. 

In one embodiment, the server establishes a connection with all of the clients and 
sends a small amount of test data to the client along with an instruction to send a reply 
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back to the server. The length of time required to reply is used as a performance 
parameter that is compared with the performance parameter of other clients to help 
determine the group of primary clients. The primary clients are then sent the multicast 
information directly from the server and the primary clients are each responsible to 
forward the multicast information to one or more other clients. 

In addition to considering the performance of the clients, the multicast server may 
also take into consideration the network location of various candidate primary clients for 
the purpose of insuring that different areas of the network are populated by a suitable 
number of primary clients. The term, "network location" is used to refer to the relative 
position of the clients in the network considering the various connection to routers and 
other clients. Network location may or may not be related to physical location. A client 
could theoretically be physically located next to another client but connected to a 
completely different system of routers. In such a case, the clients would have the same 
physical location, but would be far apart with respect to their network location. This 
ensures that packets are not unnecessarily forwarded a great distance in the network from 
the primary client to a secondary client that receives multicast data from the primary 
client. 

For example, referring back to the network shown in Figure 2A, clients 202a, 
202b, and 202c are all connected to the same router A. Router A is sometimes referred to 
as a leaf router because it is the last router in a chain of routers that is connected to a set 
of clients. Because clients 202a, 202b and 202c are all connected to the same router, it 
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would be advantageous if one of those clients were designated as a primary client and if 
that primary client forwarded packets to the other two clients. 

Thus, in one embodiment, the server pings the clients and traces the route that 
packets travel from the clients to the server. In this manner, if the server recognizes 
router A as the last router between the server and several clients, it can conclude that 
those clients have a similar network location and the server may insure that at least one of 
those clients is selected as a primary client even if one of those clients is not one of the 
best performing clients over all. 

Clients may be grouped together by network location, not only by leaf router, but 
also by a router that is further removed. For example, clients 202a through 202f are all 
connected through different leaf routers to Router B. The server may consider this larger 
grouping in determining the set of primary clients. 

A number of schemes are used in different embodiments to determine primary 
clients and assign clients to other clients. As noted above, in one embodiment, both 
network location and client performance are considered. Also, performance may be 
evaluated for all of the clients or for only enough clients until a suitable number of 
primary clients are designated. In an embodiment where all the clients are evaluated, the 
clients are first grouped by network location. The number of groups may be required to 
be less than the number of primary clients that can be served by the server. Clients 
within groups are compared for performance and a set of primary clients is selected. If 
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the number of groups is less than the total number of primary clients, then the server may 
select additional primary clients based on performance. 

Preference may be given to clients in groups that have a large number of clients. 
In one embodiment, this is implemented by setting different performance thresholds for 
clients in different groups to become primary clients. For example, the first client in the 
group may have to exceed a relatively low performance threshold to become a primary 
client but the second best client in that group may have to exceed a higher threshold. As 
can be appreciated, different schemes are preferred under different conditions. In some 
embodiments, network location may not be considered exclusively or not at all. 

It should also be noted that the clients may sign onto the multicast not all at once 
but one at a time. In such a case, each client may be evaluated as it signs up to determine 
whether it should be a primary client. In other embodiments, a client may become a 
primary client only after it has successfully received the multicast for a certain period of 
time. During the multicast, clients may be designated or undesignated as primary clients 
based on periodic monitoring of their performance. Once the client is forwarding packets 
to another client, its performance in forwarding packets may be evaluated by determining 
the performance of the clients that are receiving the forwarded packets. 

It should also be noted that, so far, only primary clients and clients that receive 
packets from primary clients have been described in detail. In addition, clients that 
receive packets from primary clients may also be instructed to forward packets to other 
clients. Thus, primary clients forward packets secondary clients. Secondary clients 



Attorney Docket No . INT 1P21 1 



13 



PATENT 



forward packets to tertiary clients, and so on. By cascading clients in this manner, the 
number of clients in the multicast group that are served can increase very rapidly with 
little additional demand on the server's processing resources. 

The server functions to monitor the location and performance of all of the clients 
in the multicast group. The server directs certain clients to forward packets to other 
clients. The server need only directly send packets to the primary clients. Thus, for the 
purpose of control, the server is connected to all of the clients. This control connection 
includes a relatively light amount of data traffic. For the purpose of sending significant 
amounts of data, the server is only connected to the primary clients. 

Figure 2B is a block diagram illustrating the topology of the data network. A 
server 210 provides multicast data to a web of clients 212. Server 210 only sends data 
directly to the first set of four primary clients. The data is forwarded from the primary 
clients to the next level of secondary clients. Data may be forwarded to multiple 
cascaded levels of clients. In one embodiment, data is forwarded through up to ten levels 
of clients. In some embodiments, it is advantageous to set a limit to the number of 
forwarding stages to limit latency to the last clients in the forwarding tree. 

Figure 2C is a block diagram illustrating the network topology for control 
information. For the purpose of control information (i.e. receiving performance data, and 
directing clients to forward and receive clients from other clients) the server is connected 
to each of the clients. Server 210 establishes contact with each of the clients 212 to give 
instructions to the clients and to measure performance. Thus, the server is able via the 
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control topology illustrated in Figure 2C to virtually construct the data topology 
illustrated in Figure 2B. The data topology is continually changing as the server may 
instruct clients to forward packets to new clients that sign up or may change assigned 
clients based on measures of performance for the purpose of optimizing the network. 

It should be noted, that although one server is shown in the preceding diagrams 
for the purpose of illustration, the function of the server may be shared among a group of 
servers. Also, in the embodiments shown, the primary clients that receive direct 
connections are actual clients, that is, they receive information from the server primarily 
for the purpose of receiving the multicast and presenting the information to a user. In 
some embodiments, a primary client that is not really a client but actually a server may be 
planted in the network at a strategic location where it can serve a large number of clients. 
As is described below, a server may be used as a backup for primary clients so that when 
a primary client fails, that server may immediately and reliably take over the task of 
forwarding packets to the secondary clients connected to the primary client. In this 
manner, a high degree of reliability may be obtained even though diverse client platforms 
are used to forward packets. 

Figure 3A is a block diagram illustrating the structure of a server used in one 
embodiment. A processor 300 is connected to a user interface 302 that is used to 
program and configure the server. Processor 300 is also connected to a memory 304 that 
may include both volatile and non volatile memory elements as well as disc or tape 
drives. The memory is used by the processor to store the network configuration and also 
to temporarily store packets that are being forwarded to the various primary clients 
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connected to the server. A network interface 306 is connected to processor 300. 
Network interface 306 handles both the control connections to all of the clients as well as 
the data connections to the set of primary clients. In addition, network interface 306 may 
send applets to the clients that enable clients to forward packets to other clients and to 
receive instructions from the server. 

Figure 3B is a block diagram illustrating the structure of a client. A processor 310 
is connected to a user interface 312. User interface 312 is generally used to display the 
multicast data to the user of the client. In addition, processor 310 implements a program 
that enables the client upon receiving instructions from the server to forward packets 
corresponding to the multicast being displayed to the user to another client. Memory 3 14 
is used to store the program and packet information for the purpose of forwarding packets 
in response to instructions received from the server. Network interface 316 is used to 
receive packets from the server or another client and to forward the packets to other 
clients as required. In one embodiment, the server is a Unix server. The client is 
implemented on a web browser and the program for forwarding to other clients is 
delivered to the client using a Java applet. 

Figure 4 is a flowchart illustrating a process implemented on the server for 
signing up a new client. A subscription request is received at 402. The request is 
authenticated in a step 404. In general, the server must insure that the client signing up 
for the multicast is an authorized client. Next in a step 406, the server pings the client for 
the purpose of determining a trace route from the client to the server. The server may 
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also send some data to the client and request that the data be forwarded back to the server 
for the purpose of determining the performance of the client. 

Next, in a step 408, the server determines whether to make the client a primary 
client. If the client is not to be a primary client, then control is transferred to a step 410 
and the server determines a client that will be the transmitting client for the new client. 
As described above, the determination of whether the client will be a primary client may 
be made by taking into consideration both the network location of the client and the 
performance of the client. Likewise, the determination of a transmitting client may be 
made by considering network location, performance, or some combination of the two. 

Next, in a step 412, the server sends a message to the transmitting client 
instructing the transmitting client to begin sending multicast data to the new client. In 
addition, the server may instruct the new client to forward packets to another client 
Control is then transferred to a step 418 and the server continues to monitor client events. 
In one embodiment, each client installs an application that enables it to receive server 
instructions and to forward packets to other clients when so instructed. In other 
embodiments, an applet may be sent to a client that enables the client to forward packets 
while packets are being received. 

If, in step 408, it is determined that the client is to be a primary client, then, in 
step 416 the server sets up a direct connection with the client and begins to forward 
multicast data to the client. As noted above, the server may actually instruct another 
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server to send data directly to the primary client in an implementation where multiple 
servers are used. 

Figure 5 is a flowchart illustrating a process implemented on the server for 
beginning a multicast with a multiple number of clients. The process starts at 500. In a 
step 502 the server pings the clients for the purpose of obtaining trace routes and 
determining the performance of the clients. Next, in a step 504, the clients are sorted 
according to the routers indicated by the trace. In one embodiment, the clients are 
clustered using a heuristic algorithm that organizes the clients into suitably sized groups. 
Next, in a step 506, the best performing clients in each cluster are designated to be 
primary clients. Next, in a step 508, the best remaining clients are selected as secondary 
clients. In different embodiments, the process may continue to assign further levels of 
clients based on their performance and location. In step 510, the remaining clients are 
assigned to other clients and the process ends at 512. 

Thus, the server initiates the multicast by obtaining information about the network 
location and performance of each of the clients and selecting various levels of clients to 
forward to other clients. A direct connection is established with the primary clients and 
instructions are sent to clients to set up client-client forwarding relationships. 

Figure 6A is a diagram illustrating a primary client data structure used in the 
server to store a list of primary clients. The data structure simply includes a list of 
suitable client identifiers such as an IP address for each of the primary clients. In the 
example shown, primary clients 610, 612, 614 and 616 are included in the list. 
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Figure 6B is a diagram illustrating a client record that may be kept by the server 
for each of the clients. The client record includes a client ID 620. A performance 
parameter 622 that represents the performance of the client measured when the server 
pings a client is also included. In addition, a transmit performance parameter 624 may be 
stored that represents the reported performance of the transmitting client from a receiving 
client that is receiving a transmission from the transmitting client. Also, a receive 
performance parameter 626 may be included that represents a report from the client 
indicating the rate at which data is successfully being received from the server or from 
whatever client is transmitting to the client. 

A list of routers 628, 630, 632, 634, and 636 is also included that represent the 
routers determined by a trace route that are approximate to the client in the network. In 
different embodiments, the number of routers listed may vary. The router list is used to 
define the client's network location. A receive client field 638 and a receive client field 
640 are also included. Those fields are used to store the identity of clients to which the 
client is transmitting. In different embodiments, different numbers of fields of receive 
clients may be included. 

Figure 7 is a flowchart illustrating a process implemented on the server for 
monitoring clients. The server sends a request to the client that periodically causes the 
client to send a performance report to the server. Such a performance report is received 
in a step 700. Next, in a step 702, the transmit performance is stored for the transmitting 
client that is sending information to a client that sent the performance report. The same 
performance may be stored as the receive performance of the reporting client. It should 
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also be noted that the client may be a primary client in which case the client receives 
information directly from the server so that there is no transmitting client. 

In a step 704, it is determined whether a receiving client performance is below a 
threshold. If the received performance is below the threshold, then control is transferred 
to a step 706 and the receiving client is reassigned to a new transmitting client or to a 
server. As noted above, a special server may be designated for the purpose of 
transferring clients that are not receiving good performance for the multicast. The 
receiving client is reassigned by simply sending a message to the new client or server to 
begin transmitting information to the client. In addition, a message may be sent to the 
receiving client indicating that multicast information will now be received from a new 
source. Once this is done, control is transferred to step 708 and the server continues 
monitoring events. In one embodiment, performance is determined by the streaming data 
rate. In other embodiments, other measures of performance are used, such as the latency 
from the server. 

If, in step 704, it is determined that the received performance is above the 
acceptable threshold, then the performance is stored for the receiving client in step 710 
and control is transferred to step 708. 

Thus, the server continually receives reports from clients and evaluates the 
performance enjoyed by those clients. In this manner, the server can insure a high level 
of performance for each of the clients even though the server does not directly handle 
forwarding information packets to the clients. Instead, the server monitors performance 
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and assures that clients that are not receiving good performance are directed to a new 
transmitting client or server. In addition, the performance reports are stored so that new 
clients may be assigned to transmitting clients that are performing well 

Figure 8 is a flowchart illustrating a process implemented on the server for 
reassigning clients of a failed transmitting client to a new transmitting client. Preferably, 
the reassignment is accomplished without disturbing the tree of clients below the failed 
transmitting client. In addition to periodically sending a performance report to the server, 
the clients may also detect that no data is being received from their transmitting client or 
that the rate of data being received has dropped below an acceptable threshold. In such a 
case the client will send an error message to the server indicating that the transmitting 
client has failed. The client may also autonomously seek an alternative source from a 
pre-defined list. Such a message is received in step 802 by the server that a client is not 
receiving data. Control is then transferred to a step 804 and it is checked whether the 
client is flagged as belonging to a tree of clients below a non-performing server. 

As described above, the clients may be cascaded through multiple levels. When 
the client at the top of a large branch of clients stops receiving data from its transmitting 
client, that client will eventually run out of data to transmit to the clients branching from 
it. However, if the client at the top of the branch has not failed, there is no reason to 
reconstruct the branch. The branch may simply be attached to a different transmitting 
client at the top. Fortunately, the first client in the branch to determine that multicast data 
is not being received should be the top client in the branch. There will be some delay 
before that client runs out of data to send to the clients below it. Thus, when the top 
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client indicates the data is not being received, all the clients in its branch below it may be 
temporarily flagged so that those clients will not be reassigned when they report that they 
are not receiving data unless, in fact, the top client in the branch has failed. 

If, in step 804, it is determined that the client is not flagged, then, in step 806, the 
clients in the branch below the client that sent the message that are directly or indirectly 
receiving data from the non receiving client are flagged so that four error messages will 
temporarily be ignored by the server. In one embodiment, clients that are not receiving 
data are configured to repeatedly send error messages so that ignoring initial error 
messages is not a problem. Another error message will be sent. In other embodiments, 
the flag may cause the error message to be temporarily buffered and reconsidered later by 
the server. After clients in the branch of the non receiving client are flagged in step 806, 
control is transferred to a step 808 and the non receiving client is pinged to determine if 
the non receiving client has failed. This is necessary because it may be that the 
transmitting client is transmitting, but the non receiving client sending an error message 
may have a problem with its network interface that is preventing it from receiving the 
transmission. 

If the non receiving client has failed, then control is transferred to a step 810 and 
the clients in the branch that received from the non receiving client are assigned to a new 
sending client. As noted above, the new sending client may actually be a special server 
designated for the purpose of taking care of clients that have had a problem. Next, in a 
step 812 the message is sent to the non receiving client so that the non receiving client 
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can reconfigure and hopefully begin successfully receiving the multicast. Control is then 
transferred to step 816 and the server continues to monitor messages from clients. 

If, in step 804, it is determined that the client is flagged, then control is transferred 
to a step 818 and the message from the client is discarded. As described above, such a 
message would be sent by a client in a branch where the client at the top of its branch 
stopped receiving data from its transmitting client as a result of failure of that 
transmitting client. After step 818, control is transferred to step 816. If, in step 808, it is 
determined that the non receiving client has not failed, then control is transferred to step 
814 and a new sender is assigned to the non receiving client. Control is then transferred 
to step 816. 

Thus, clients report problems with receiving multicast information. The server 
determines whether the source of the problem is the client itself or the client that is 
transmitting to the reporting client. Meanwhile, the branch below the non receiving 
client is kept intact so that it may be regrafted as a whole to a new transmitting client if 
necessary. In this manner, the amount of reconfiguration required when a failure occurs 
within the network is minimized. 

The server request instructs a client to execute a set of relatively simple 
procedures for the client to report back to the server data that enables the server to 
manage the flexible network topology. Figure 9A is a flowchart illustrating a process for 
sending an error message. In a step 902, the client detects that it is no longer receiving 
data from its sending client. An error message is sent in a step 904. As described above, 
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the error message may be repeatedly sent if the loss of transmission is continued to be 
detected. 

Figure 9B is a flowchart illustrating a process for sending statistics to the server. 
The process starts at 910. In a step 912, statistics are gathered by the receiving client. In 
a step 914, statistics are periodically sent to the server. 

Figure 9C is a flowchart illustrating a process implemented on a client to forward 
packets to another client. In a step 920 a command is received from the server to transmit 
to the new client. Next, in a step 922, the client starts forwarding packets to the 
forwarding address of the new client specified by the server. 

Thus, the server is able to construct a forwarding network topology where clients 
are designated to receive packets from the server or another client and forward those 
packets to other clients. A number of cascading levels of clients may be implemented. In 
this manner, information is spread to a large number of clients very quickly. The server 
is able to adjust the topology of the forwarding tree of clients based on periodic 
performance reports from the clients as well as error messages indicating that part of the 
tree has failed. When a client fails, the branch of clients receiving data from that client 
are transferred to another transmitting client with a minimum of reconfiguration required. 
Because both location and performance are used by the server to determine the topology 
of the client forwarding tree, network resources can be utilized efficiently and a multicast 
system can be implemented without requiring multicast enabled routers to be universally 
adopted within the network. 
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Although the foregoing invention has been described in some detail for purposes 
of clarity of understanding, it will be apparent that certain changes and modifications may 
be practiced within the scope of the appended claims. It should be noted that there are 
many alternative ways of implementing both the process and apparatus of the present 
invention. Accordingly, the present embodiments are to be considered as illustrative and 
not restrictive, and the invention is not to be limited to the details given herein, but may 
be modified within the scope and equivalents of the appended claims. 

WHAT IS CLAIMED IS: 
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CLAIMS 



1 . A method of multicasting information to a set of clients comprising: 
transmitting the information to a primary client from a server; and 
instructing the primary client to forward the information to a secondary client. 

2. A method of multicasting information to a set of clients as recited in claim 1 
further including receiving performance information from the set of clients. 

3. A method of transmitting a customized offer to an applicant as recited in claim 1 
further including pinging clients to determine the network location of the clients. 

4. A method of transmitting a customized offer to an applicant as recited in claim 1 
wherein the information is streaming video. 

5. A method of multicasting information to a set of clients comprising: 
determining a performance parameter for each of the clients; 

selecting a subset of the clients to be primary clients based on the performance 
parameter; 

transmitting the information to the primary clients for retransmission to other 
clients in the set of clients. 

6. A method of multicasting information to a set of clients comprising: 
determining a network location for each of the clients; 

selecting a subset of the clients to be primary clients based on the network 
location; 

transmitting the information to the primary clients for retransmission other clients 
in the set of clients. 

7. A method of multicasting information to a set of clients comprising: 
determining a network location for each of the clients; 
determining a performance parameter for each of the clients; 

selecting a subset of the clients to be primary clients based on the performance 
parameter and the determined network location; 

transmitting the information to the primary clients for retransmission other clients 
in the set of clients. 
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8. A method of adding a new client to a multicast group comprising: 
receiving a request from the new client to subscribe to the multicast group; 
selecting an existing client to transmit information to the new client based on the 

network locations of the new client and the existing client and a comparison of a 
performance parameter of the existing client with performance parameters of other 
existing clients. 

9. A method of subscribing to a multicast group comprising: 

sending a request to a server from a subscribing client to subscribe to the 
multicast group; and 

receiving from the server an identifier of a transmitting client that will send data 
to the subscribing client; and 

receiving the data from the transmitting client. 

10. A method of forwarding information from a transmitting client to a receiving 
client in a multicast group comprising: 

receiving an instruction from a multicast server to forward information to the 
receiving client; 

receiving the information; and 

forwarding the information to the receiving client. 

11. A method of multicasting information to a set of clients as recited in claim 10 
further including displaying the information to a user. 

12. A method of multicasting information to a set of clients as recited in claim 10 
further including displaying the information to a user without positively indicating to the 
user that the information is being forwarded. 

13. A method of redirecting a receiving multicast client from a failed transmitting 
client comprising: 

receiving a message from the receiving client that information is not being 
received; 

sending a message to the receiving client indicating a new source of the 
information; and 
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sending a message to the new source directing the new source to send the 
information to the receiving client. 

14. A method of redirecting a receiving multicast client from a failed transmitting 
client as recited in claim 13 further including: 

flagging a set of secondary receiving clients that are to receive the information 
from the receiving client so that the receiving client will not be failed in the event that a 
secondary receiving client sends a message indicating that information is not being 
received. 

15. A method of redirecting a receiving multicast client from a failed transmitting 
client as recited in claim 13 further including: 

sending a test message to the receiving client; 

in the event that a valid response to the test message is not received, failing the 
receiving client and sending a message to a set of secondary receiving clients that are to 
receive the information from the receiving client that directs the secondary receiving 
clients to receive information from a new source. 

16. A method of redirecting a receiving multicast client from a failed transmitting 
client as recited in claim 13 wherein the new source is a dedicated backup server that 
reliably sends information to redirected clients. 

17. A method of redirecting a receiving multicast client from an under performing 
transmitting client comprising: 

receiving a message from the receiving client indicating the rate that information 
is being received; 

determining that the information rate falls below a performance standard; 
sending a message to the receiving client indicating a new source of the 
information; and 

sending a message to the new source directing the new source to send the 
information to the receiving client. 

18. A server configured to multicast information to a set of clients comprising: 
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a client interface configured to transmit the information to a primary client from 
the server and to instruct the primary client to forward the information to a secondary 
client. 

19. A client configured to forward multicast information to another client comprising: 
a server interface configured to receive the information from the server; and 

a client interface configured to forward the information to the other client. 

20. A system for multicasting information to a set of clients comprising: 
a server configured to transmit the information; and 

a primary client configured to receive the transmitted information and to forward 
the information to a secondary client. 

21. A computer program product for multicasting information, the computer program 
product being embodied in a computer readable medium and comprising computer 
instructions for: 

transmitting the information to a primary client from a server; and 
instructing the primary client to forward the information to a secondary client. 
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MULTICAST SYSTEM USING CLIENT FORWARDING 



ABSTRACT OF THE DISCLOSURE 

A system and method are disclosed for multicasting information to a set of clients 
that includes transmitting the information to a primary client from a server and 
instructing the primary client to forward the information to a secondary client. 
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